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Docket No.: 10559/398001/P10335 

INVERSE HALFTONING PROCESS 

TECHNICAL FIELD 

This invention relates to inverse halftoning. 

5 

BACKGROUND 

Digital halftoning recreates an original shaded image 
using light and dark pixels. Varying the density and 
placement of the light and dark pixels in the resulting 
10 digitally-half toned image approximates shading gradations in 
the original image. Inverse halftoning is a process of 
enhancing a digitally-half toned image so that it more closely 
resembles the original shaded image. 

15 DESCRIPTION OF THE DRAWINGS 

Fig. 1 is a flowchart showing an inverse-halftoning 
process according to one embodiment of the invention. 

Fig. 2 is a view of pixels in images processed by the 
inverse halftoning process. 
20 Fig. 3 is a block diagram of computer hardware on which 

the inverse halftoning process may be implemented- 
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DESCRIPTION 

Referring to Fig. 1, a process 5 is shown for performing 
inverse halftoning on a half toned image. Process 5 is 
basically a two-part processor with enhancements. In Fig. 1, 
5 the enhancements are shown by dotted lines. 

In the basic two-part process^, process 5 lightly smoothes 
(101) the half toned image and then performs (103) lowpass 
filtering on the half toned image. To lightly smooth the 
half toned image, process 5 applies a two-dimensional (e.g., 
10 NxN, where N>1) filter to each pixel in the image. 

In one embodiment, a strongly-peaked 3x3 filter is used 
to perform the light smoothing. Examples of filters to 
produce different shading effects are (A) and (B) below. 



15 
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6 8 6^ (1/36) 
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1 2 1 

2 8 2 * (1/20) 
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(A) 



(B) 



A filter is applied to an image as follows. The filter 
matrix is overlaid on a block of NxN (e.g., 3x3) pixels. Each 
20 numerical value in the filter matrix is multiplied by a 

corresponding underlying pixel value. The resulting products 
are added together and multiplied by the reciprocal of the sum 
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of the filter values (e.g., (1/36) and (1/20) above). The 
resulting value is stored as a pixel in an intermediary 
smoothed image. The pixel in the intermediary smoothed image 
is at the same location in the smoothed image as the center 
5 pixel in the block of NxN pixels that were filtered in the 
original image. 

To process other pixels, the filter matrix is moved to an 
adjacent pixel in the original image. The filter matrix may 
be moved horizontally or vertically. Referring to Fig. 2, as 

10 each pixel 6 in an original image 7 is processed^, the 

resulting filtered pixel is stored at a corresponding location 
8 in a smoothed image 9. The resulting smoothed image, or 
portion thereof, is lowpass filtered to produce an enhanced 
image. Lowpass filtering is performed in order to reduce 

15 artifacts in the image. Examples of artifacts include 
unwanted spots or image aberrations. 

Process 5 performs (103) lowpass filtering using a one- 
dimensional lowpass filter having a relatively sharp high- 
frequency cutoff. Examples of well-known lowpass filters that 

20 have sharp high-frequency cutoffs, and that may be used, 

include Hamming and Kaiser filters. In this embodiment, a 
one-dimensional filter with N (N^l) taps is used; however, a 
two-dimensional filter, whose dimensions in some, but not all. 
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instances will be NxN, may be used to perforin the lowpass 
filtering. The lowpass filter may have any number of "taps'V 
e.g.; 11^ If ?>f etc.^ and may be weighted by a sine function 
to vary filter width. The lowpass filter is moved over the 
5 smoothed image, and filters the smoothed image, in much the 
same way as the 3x3 filter described above. 

However, unlike the case of filtering with a 3x3 two- 
dimensional matrix, filtering with a one-dimensional matrix is 
done by making two passes, one horizontal and one vertical, 

10 over the image. First, the lowpass matrix is overlaid along 

either a block of row pixels and moved horizontally or a block 
of column pixels and moved vertically to create an 
intermediate image. On the second pass, the filter is applied 
to the intermediate image along the direction not applied in 

15 the first pass. For example, a filter having the matrix 
values 

16 1 

may be used along a row. As above, each numerical value in 
20 the filter is multiplied by a corresponding underlying pixel 
value. The resulting products are added together and 
multiplied by the reciprocal of the sum of the filter values. 
The resulting value is assigned to a pixel in an intermediate 
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image. In the second pass, because filtering was done along 
rows in the first pass^ filtering is performed along columns. 
Thus^ the filter is oriented in the vertical direction with 
the following values 

5 1 

6 
1 

so that the filter values overlay pixels in a column of the 
10 intermediate image. As in the first pass, each numerical 
value in the filter is multiplied by a corresponding 
underlying pixel value. The resulting products are added 
together and multiplied by the reciprocal of the sum of the 
filter values. The resulting value is assigned to a pixel in 
15 the final, "enhanced", inverse-half toned image. 

The value is assigned to a pixel in the enhanced image 
that has the same location in the enhanced image as the pixel 
below the center pixel of the lowpass filter in the smoothed 
image. For example, as shown in Fig. 2, N-tap lowpass filter 
20 is applied to pixels 12, 14 and 16 of smoothed image 9, The 
resulting filtered value is assigned to pixel 20 in enhanced 
image 22. Pixel 20 in enhanced image 22 is at the same 
location as pixel 14 in smoothed image 9, which is at the 
center of the lowpass filter. 
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To process other pixels in the smoothed image^ the 
lowpass filter is moved to an adjacent pixel in the smoothed 
image. That adjacent pixel is then processed using the two- 
pass filtering described above. As each pixel in the smoothed 
5 image is processed, the resulting filtered pixel value is 

stored at a corresponding location in the enhanced image. By 
repeating this process for plural pixels in the smoothed 
image, process 5 generates (104) an enhanced, inverse- 
half toned, version of the smoothed image, 
.fl 10 Additional features may be incorporated into process 5. 

Ill These features are shown in dotted lines on Fig. 1. For 

ill example, process 5 may detect (102) edges in the smoothed 

image and ignore the edges during lowpass filtering (103) , 
rS i.e., only lowpass-f ilter the non-edge areas of the smoothed 

V 15 image. Thus, in this case, the enhanced image is comprised of 
the edge areas of the smoothed image and lowpass-f iltered non- 
edge areas of the smoothed image. One reason for ignoring the 
edges during lowpass filtering is that lowpass filtering tends 
to blur the image. To ensure that the edges remain relatively 
20 defined, process 5 may detect those edges and perform lowpass 
filtering selectively, such that the edges are not lowpass 
filtered. 
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To detect edges in the smoothed image,, process 5 applies 
an edge filter to the smoothed image. The edge filter may be 
an NxN filter, which processes pixels in substantially the 
same manner as the NxN filter described above. That is, the 

5 filter matrix is overlaid on a block of NxN (e.g., 3x3) 

pixels. Each numerical value in the filter is multiplied by a 
corresponding underlying pixel value. The resulting products 
are added together to obtain a value. In this case, unlike 
above, the value is not multiplied by the reciprocal of the 

10 sum of the pixel values. If the resulting value has a large 
magnitude, that is an indication of an edge in the image. 

One example of an edge detection filter matrix that may 
be used in this embodiment is as follows: 



-1 0 1 

15 -10 1 

-1 0 1 



Applying this edge detection filter to a flat surface of a 
pixel would result in a near zero value, since the pixels 
underneath the first column (-I's) would cancel the pixels 
20 underneath the third column (I's), If an edge is present at 
the center column, the value resulting from applying the 
filter over the center pixel and its adjacent eight pixels 
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would result in a non-zero magnitude because values along one 
center are different from other adjacent values. The higher 
this magnitude, the more pronounced the edge. 

Process 5 compares the value that results from applying 

5 the edge detection filter to a threshold value. Edges whose 
values exceed the threshold are ignored during lowpass 
filtering. This threshold value is set beforehand and is set, 
as desired, to ignore some edges and account for others. The 
higher that the threshold value is set, the more edges the 

10 process 5 ignores during lowpass filtering (103). That is, if 
the threshold is set relatively high, only highly-pronounced 
edges will not be subjected to lowpass filtering, whereas if 
the threshold is set relatively low, relatively less- 
pronounced edges will also not be subjected to lowpass 

15 filtering. 

Process 5 may also apply (105) a median filter to the 
resulting enhanced image. The median filter is designed to 
reduce artifacts, such as spots or other aberrations, in the 
enhanced image. The median filter may also be an NxN filter, 

20 which is applied in the manner described above, to further 

smooth the enhanced image. The median filter may be applied 
to non-edge portions of the enhanced image only, if desired. 
In this case, an edge detection filter of the type described 
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above is used to detect edges in the enhanced image prior to 
applying the median filter to the enhanced image. 

Fig. 3 shows a computer 28 on which process 5 may be 
implemented. Computer 28 includes a processor 30, a memory 

6 32, and a storage medium 34 (see view 36) . Storage medium 34 
stores data 38 for one or more images and machine-executable 
instructions 40 that are executed by processor 30 out of 
memory 32 to perform inverse halftoning process 5. 

Although a personal computer is shown in Fig. 3, process 

10 5 is not limited to use with the hardware and software of Fig. 
3. It may find applicability in any computing or processing 
environment. Process 5 may be implemented in hardware, 
software, or a combination of the two. Process 5 may be 
implemented in computer programs executing on programmable 

15 computers or other machines that each include a processor, a 
storage medium readable by the processor (including volatile 
and non-volatile memory and/or storage components), at least 
one input device, and one or more output devices. Program 
code may be applied to data entered using an input device 

20 (e.g., a mouse or keyboard) to perform process 5 and to 
generate output information. 

Each such program may be implemented in a high level 
procedural or object-oriented programming language to 
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communicate with a computer system. However, the programs can 
be implemented in assembly or machine language. The language 
may be a compiled or an interpreted language. 

Each computer program may be stored on a storage medium/ 
article (e.g., CD-ROM, hard disk, or magnetic diskette) that 
is readable by a general or special purpose programmable 
computer for configuring and operating the computer when the 
storage medium or device is read by the computer to perform 
process 5. Process 5 may also be implemented as a machine- 
readable storage medium, configured with a computer program, 
where, upon execution, instructions in the computer program 
cause a machine to operate in accordance with process 5. 

The invention is not limited to the specific embodiments 
described above. For example, a Sobel gradient operator may 
be used for edge detection instead of, or in addition to, the 
NxN matrix described above. The invention is not limited to 
the specific filters described herein, to their numerical 
values, or to their dimensions. The invention can be used to 
perform inverse halftoning on images received over a network 
or on any other types of half toned images - 

Other embodiments not described herein are also within 
the scope of the following claims. 

What is claimed is: 
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